}
static void
-gtk_css_token_initv (GtkCssToken *token,
- GtkCssTokenType type,
- va_list args)
+gtk_css_token_init (GtkCssToken *token,
+ GtkCssTokenType type)
{
token->type = type;
- switch (type)
+ switch ((guint)type)
{
- case GTK_CSS_TOKEN_STRING:
- case GTK_CSS_TOKEN_IDENT:
- case GTK_CSS_TOKEN_FUNCTION:
- case GTK_CSS_TOKEN_AT_KEYWORD:
- case GTK_CSS_TOKEN_HASH_UNRESTRICTED:
- case GTK_CSS_TOKEN_HASH_ID:
- case GTK_CSS_TOKEN_URL:
- token->string.string = va_arg (args, char *);
- break;
-
- case GTK_CSS_TOKEN_DELIM:
- token->delim.delim = va_arg (args, gunichar);
- break;
-
- case GTK_CSS_TOKEN_SIGNED_INTEGER:
- case GTK_CSS_TOKEN_SIGNLESS_INTEGER:
- case GTK_CSS_TOKEN_SIGNED_NUMBER:
- case GTK_CSS_TOKEN_SIGNLESS_NUMBER:
- case GTK_CSS_TOKEN_PERCENTAGE:
- token->number.number = va_arg (args, double);
- break;
-
- case GTK_CSS_TOKEN_SIGNED_INTEGER_DIMENSION:
- case GTK_CSS_TOKEN_SIGNLESS_INTEGER_DIMENSION:
- case GTK_CSS_TOKEN_DIMENSION:
- token->dimension.value = va_arg (args, double);
- token->dimension.dimension = va_arg (args, char *);
- break;
-
- default:
- g_assert_not_reached ();
case GTK_CSS_TOKEN_EOF:
case GTK_CSS_TOKEN_WHITESPACE:
case GTK_CSS_TOKEN_OPEN_PARENS:
case GTK_CSS_TOKEN_BAD_URL:
case GTK_CSS_TOKEN_COMMENT:
break;
+ default:
+ g_assert_not_reached ();
}
}
}
static void
-gtk_css_token_init (GtkCssToken *token,
- GtkCssTokenType type,
- ...)
+gtk_css_token_init_string (GtkCssToken *token,
+ GtkCssTokenType type,
+ char *string)
{
- va_list args;
+ token->type = type;
- va_start (args, type);
- gtk_css_token_initv (token, type, args);
- va_end (args);
+ switch ((guint)type)
+ {
+ case GTK_CSS_TOKEN_STRING:
+ case GTK_CSS_TOKEN_IDENT:
+ case GTK_CSS_TOKEN_FUNCTION:
+ case GTK_CSS_TOKEN_AT_KEYWORD:
+ case GTK_CSS_TOKEN_HASH_UNRESTRICTED:
+ case GTK_CSS_TOKEN_HASH_ID:
+ case GTK_CSS_TOKEN_URL:
+ token->string.string = string;
+ break;
+ default:
+ g_assert_not_reached ();
+ }
+}
+
+static void
+gtk_css_token_init_delim (GtkCssToken *token,
+ gunichar delim)
+{
+ token->type = GTK_CSS_TOKEN_DELIM;
+ token->delim.delim = delim;
+}
+
+static void
+gtk_css_token_init_number (GtkCssToken *token,
+ GtkCssTokenType type,
+ double value)
+{
+ token->type = type;
+
+ switch ((guint)type)
+ {
+ case GTK_CSS_TOKEN_SIGNED_INTEGER:
+ case GTK_CSS_TOKEN_SIGNLESS_INTEGER:
+ case GTK_CSS_TOKEN_SIGNED_NUMBER:
+ case GTK_CSS_TOKEN_SIGNLESS_NUMBER:
+ case GTK_CSS_TOKEN_PERCENTAGE:
+ token->number.number = value;
+ break;
+ default:
+ g_assert_not_reached ();
+ }
+}
+
+static void
+gtk_css_token_init_dimension (GtkCssToken *token,
+ GtkCssTokenType type,
+ double value,
+ char *dimension)
+{
+ token->type = type;
+
+ switch ((guint)type)
+ {
+ case GTK_CSS_TOKEN_SIGNED_INTEGER_DIMENSION:
+ case GTK_CSS_TOKEN_SIGNLESS_INTEGER_DIMENSION:
+ case GTK_CSS_TOKEN_DIMENSION:
+ token->dimension.value = value;
+ token->dimension.dimension = dimension;
+ break;
+ default:
+ g_assert_not_reached ();
+ }
}
GtkCssTokenizer *
}
}
- gtk_css_token_init (token, GTK_CSS_TOKEN_URL, g_string_free (url, FALSE));
+ gtk_css_token_init_string (token, GTK_CSS_TOKEN_URL, g_string_free (url, FALSE));
return TRUE;
}
}
}
- gtk_css_token_init (token, GTK_CSS_TOKEN_FUNCTION, name);
+ gtk_css_token_init_string (token, GTK_CSS_TOKEN_FUNCTION, name);
return TRUE;
}
else
{
- gtk_css_token_init (token, GTK_CSS_TOKEN_IDENT, name);
+ gtk_css_token_init_string (token, GTK_CSS_TOKEN_IDENT, name);
return TRUE;
}
}
gint64 integer, fractional = 0, fractional_length = 1, exponent = 0;
gboolean is_int = TRUE, has_sign = FALSE;
const char *data = tokenizer->data;
+ double value;
if (*data == '-')
{
gtk_css_tokenizer_consume (tokenizer, data - tokenizer->data, data - tokenizer->data);
+ value = sign * (integer + ((double) fractional / fractional_length)) * pow (10, exponent_sign * exponent);
+
if (gtk_css_tokenizer_has_identifier (tokenizer))
{
- gtk_css_token_init (token,
- is_int ? (has_sign ? GTK_CSS_TOKEN_SIGNED_INTEGER_DIMENSION : GTK_CSS_TOKEN_SIGNLESS_INTEGER_DIMENSION)
- : GTK_CSS_TOKEN_DIMENSION,
- sign * (integer + ((double) fractional / fractional_length)) * pow (10, exponent_sign * exponent),
- gtk_css_tokenizer_read_name (tokenizer));
+ GtkCssTokenType type;
+
+ if (is_int)
+ type = has_sign ? GTK_CSS_TOKEN_SIGNED_INTEGER_DIMENSION : GTK_CSS_TOKEN_SIGNLESS_INTEGER_DIMENSION;
+ else
+ type = GTK_CSS_TOKEN_DIMENSION;
+
+ gtk_css_token_init_dimension (token, type, value, gtk_css_tokenizer_read_name (tokenizer));
}
else if (gtk_css_tokenizer_remaining (tokenizer) > 0 && *tokenizer->data == '%')
{
- gtk_css_token_init (token,
- GTK_CSS_TOKEN_PERCENTAGE,
- sign * (integer + ((double) fractional / fractional_length)) * pow (10, exponent_sign * exponent));
+ gtk_css_token_init_number (token, GTK_CSS_TOKEN_PERCENTAGE, value);
gtk_css_tokenizer_consume_ascii (tokenizer);
}
else
{
- gtk_css_token_init (token,
- is_int ? (has_sign ? GTK_CSS_TOKEN_SIGNED_INTEGER : GTK_CSS_TOKEN_SIGNLESS_INTEGER)
- : (has_sign ? GTK_CSS_TOKEN_SIGNED_NUMBER : GTK_CSS_TOKEN_SIGNLESS_NUMBER),
- sign * (integer + ((double) fractional / fractional_length)) * pow (10, exponent_sign * exponent));
+ GtkCssTokenType type;
+
+ if (is_int)
+ type = has_sign ? GTK_CSS_TOKEN_SIGNED_INTEGER : GTK_CSS_TOKEN_SIGNLESS_INTEGER;
+ else
+ type = has_sign ? GTK_CSS_TOKEN_SIGNED_NUMBER : GTK_CSS_TOKEN_SIGNLESS_NUMBER;
+
+ gtk_css_token_init_number (token, type,value);
}
}
gtk_css_tokenizer_read_delim (GtkCssTokenizer *tokenizer,
GtkCssToken *token)
{
- gtk_css_token_init (token, GTK_CSS_TOKEN_DELIM, g_utf8_get_char (tokenizer->data));
+ gtk_css_token_init_delim (token, g_utf8_get_char (tokenizer->data));
gtk_css_tokenizer_consume_char (tokenizer, NULL);
}
gtk_css_tokenizer_consume_char (tokenizer, string);
}
}
-
- gtk_css_token_init (token, GTK_CSS_TOKEN_STRING, g_string_free (string, FALSE));
+
+ gtk_css_token_init_string (token, GTK_CSS_TOKEN_STRING, g_string_free (string, FALSE));
return TRUE;
}
else
type = GTK_CSS_TOKEN_HASH_UNRESTRICTED;
- gtk_css_token_init (token,
- type,
- gtk_css_tokenizer_read_name (tokenizer));
+ gtk_css_token_init_string (token,
+ type,
+ gtk_css_tokenizer_read_name (tokenizer));
}
else
{
- gtk_css_token_init (token, GTK_CSS_TOKEN_DELIM, '#');
+ gtk_css_token_init_delim (token, '#');
}
return TRUE;
gtk_css_tokenizer_consume_ascii (tokenizer);
if (gtk_css_tokenizer_has_identifier (tokenizer))
{
- gtk_css_token_init (token,
- GTK_CSS_TOKEN_AT_KEYWORD,
- gtk_css_tokenizer_read_name (tokenizer));
+ gtk_css_token_init_string (token,
+ GTK_CSS_TOKEN_AT_KEYWORD,
+ gtk_css_tokenizer_read_name (tokenizer));
}
else
{
- gtk_css_token_init (token, GTK_CSS_TOKEN_DELIM, '@');
+ gtk_css_token_init_delim (token, '@');
}
return TRUE;
}
else
{
- gtk_css_token_init (token, GTK_CSS_TOKEN_DELIM, '\\');
+ gtk_css_token_init_delim (token, '\\');
gtk_css_tokenizer_consume_ascii (tokenizer);
gtk_css_tokenizer_parse_error (error, "Newline may not follow '\' escape character");
return FALSE;